2027 Method
Changes 0
M

WorksharingUtils.CheckoutWorksets

Description:
Obtains ownership for the current user of as many specified worksets as possible.
Remarks:

For best performance, check out all worksets in one big call, rather than many small calls.

When there comes a contention error when locking the central model, this API would wait and retry endlessly until getting the lock of the central model.

Overloads (2):
CheckoutWorksets(Document,ICollection[WorksetId])
public static ICollection<WorksetId> CheckoutWorksets(
	Document document,
	ICollection<WorksetId> worksetsToCheckout
)
  • document
    The document containing the worksets.
  • ICollection<WorksetId>
    worksetsToCheckout
    The ids of the worksets to attempt to check out.
Return Value ICollection<WorksetId> The ids of all specified worksets that are now owned, including all that were owned prior to the function call.
void CheckoutAllViewWorksets(Document doc)
{
    FilteredWorksetCollector collector = new FilteredWorksetCollector(doc);

    // find all view worksets
    collector.OfKind(WorksetKind.ViewWorkset);
    ICollection<WorksetId> viewworksets = collector.ToWorksetIds();
    ICollection<WorksetId> checkoutworksets = WorksharingUtils.CheckoutWorksets(doc, viewworksets);
    TaskDialog.Show("Checked out worksets", "Number of worksets checked out: " + checkoutworksets.Count);
}
  • document is not a workshared document. -or- document is not a primary document, it is a linked document. -or- document is read-only: It cannot be modified. -or- document has an open editing transaction and is accepting changes. -or- There are one or more ids with no corresponding workset. -or- Saving is not allowed in the current application mode.
  • A non-optional argument was null
  • The file-based central model could not be reached, e.g. the network is down or the file server is down.
  • Access to the central model was denied due to lack of access privileges. -or- Access to the central model was denied. A possible reason is because the model was under maintenance.
  • The central model are locked by another client.
  • The central model is overwritten by other user. -or- The central model is missing. -or- An internal error happened on the central model, please contact the server administrator.
  • Last central version merged into the local model has been archived in the central model. This exception could only be thrown from cloud models.
  • Operation is not permitted when there is any open sub-transaction, transaction, or transaction group.
  • The server-based central model could not be accessed because of a network communication error.
  • An internal error happened on the server, please contact the server administrator.